package com.bzkj.document.mapper;

import com.bzkj.document.domain.saleout.dto.SaleOutQueryDTO;
import com.bzkj.document.domain.saleout.vo.SaleOutBodyVo;
import com.bzkj.document.domain.saleout.vo.SaleOutHeaderVo;
import org.apache.ibatis.annotations.Param;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @projectName: bzkj-wms
 * @package: com.bzkj.document.mapper
 * @className: SalesOutboundMapper
 * @description: 销售出库单持久层
 * @author: C1309
 * @createDate: 2024年12月05日
 * @version: v1.0
 */
public interface SalesOutboundMapper {
    /**
     * 获取销售出库单状态
     *
     * @param cgeneralhid 单据头主键
     * @return 状态
     */
    HashMap<String, String> getBillStatus(String cgeneralhid);

    /**
     * 更新销售出库单状态
     *
     * @param cgeneralhid 单据头信息
     * @param billState   状态
     * @param userName    签名人
     * @param reason      作废原因（当为作废时必填）
     * @return 影响行数
     */
    int updateBillState(@Param("cgeneralhid") String cgeneralhid, @Param("billState") String billState,
                        @Param("userName") String userName, @Param("reason") String reason);

    /**
     * 更新销售出库单表头
     *
     * @param header 单据头信息
     * @return 修改结果
     */
    int updateSalesOutboundOrder(Map<String, Object> header);

    /**
     * 更新销售出单表体
     *
     * @param detailMap 明细信息
     * @return 修改结果
     */
    int updateSalesOutboundOrderDetails(HashMap<String, Object> detailMap);

    /**
     * 添加销售出库单头
     *
     * @param header 单据头信息
     * @return 影响行数
     */
    int addSalesOutboundOrderHeader(Map<String, Object> header);

    /**
     * 添加销售出库单详情
     *
     * @param detailMap 明细信息
     * @return 影响行数
     */
    int addSalesOutboundOrdertDetails(Map<String, Object> detailMap);

    /**
     * 查询本地销售出库单
     *
     * @param queryDTO 查询条件
     * @return 销售出库单集合
     */
    List<SaleOutHeaderVo> selectLocalSaleOutHeader(SaleOutQueryDTO queryDTO);

    /**
     * 查询本地销售出库单详情
     *
     * @param cgeneralhid 单据编号
     * @param billState   单据状态
     * @return 销售出库单详情集合
     */
    List<SaleOutBodyVo> selectLocalSaleOutDetail(@Param("cgeneralhid")String cgeneralhid,
                                                 @Param("billState") String billState);

    /**
     * 根据单据编号查询销售出库单头
     *
     * @param cgeneralhid 单据表头主键
     * @return 销售出库单头
     */
    SaleOutHeaderVo selectSaleOutHeadByBillCode(String cgeneralhid);

    /**
     * 判断本地销售出库单是否存在
     *
     * @param vbillcode
     * @return
     */
    int selectIsExist(String vbillcode);

    /**
     * 销售出库单回退
     *
     * @param headerId 单号表头主键
     * @param userName 用户名
     * @return 操作结果
     */
    int orderBackHead(@Param("headerId") String headerId, @Param("userName") String userName);

    /**
     * 撤回采购入库单表体
     *
     * @param headerId 单据号表头主键
     * @param userName 用户名
     * @return 操作结果
     */
    int orderBackDetails(@Param("headerId") String headerId, @Param("userName") String userName);
}
